package com.train.user.mapper;

import com.train.user.domain.Post;
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import org.apache.ibatis.annotations.Param;

import java.time.LocalDateTime;
import java.util.List;

/**
* @author train
* @description 针对表【sys_post(用户动态表)】的数据库操作Mapper
* @createDate 2025-10-24 16:01:41
* @Entity com.train.user.domain.Post
*/
public interface PostMapper extends BaseMapper<Post> {

    /**
     * 增加点赞数
     *
     * @param postId 动态ID
     * @return 影响行数
     */
    int incrementLikeCount(Long postId);

    /**
     * 减少点赞数
     *
     * @param postId 动态ID
     * @return 影响行数
     */
    int decrementLikeCount(Long postId);

    /**
     * 增加评论数
     *
     * @param postId 动态ID
     * @return 影响行数
     */
    int incrementCommentCount(Long postId);
    
    /**
     * 滑动查询动态列表
     * 
     * @param createTime 创建时间
     * @param postId 动态ID
     * @return 动态列表
     */
    List<Post> selectPosts(@Param("createTime") LocalDateTime createTime, @Param("postId") Long postId);
    
    /**
     * 根据话题ID滑动查询动态列表
     *
     * @param topicId 话题ID
     * @param createTime 创建时间
     * @param postId 动态ID
     * @return 动态列表
     */
    List<Post> selectPostsByTopicId(@Param("topicId") Long topicId, 
                                   @Param("createTime") LocalDateTime createTime, 
                                   @Param("postId") Long postId);
}